<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="./lib/vue.js"></script>
</head>
<body>
    <div id="app">
        <ul>
            <li v-for = "item of list" ::key="item.id">
                id : {{item.id}} <br>
                name : {{item.name | nameFormat}} <br>
                age : {{item.age}} <br>
                ctime : {{item.ctime | dateFormat}} <br>
            </li>
        </ul>

    </div>

    <script>
        //全局定义过滤器
        //第一个参数 : 表示 过滤器 管道符 前传递的数据(是必传参数)
        //作为函数可以传递第二个参数和第三个参数
        //过滤器只能在 {{}}  和 v-bind 中使用 
        Vue.filter('dateFormat', function(dateStr){
            let dt = new Date(dateStr)
            let y = dt.getFullYear()
            let m = dt.getMonth() + 1
            let d = dt.getDate()

            return `${y}-${m}-${d}`

        })
        new Vue({
            el : '#app',
            data : {
                list : [
                    {id : 1, name : 'zs' , age : 18 , ctime : new Date()},
                    {id : 2, name : 'ls' , age : 19 , ctime : new Date()}
                ]
            },
            methods : {

            },
            //私有过滤器
            filters : {
                nameFormat : function(nameStr){
                    return nameStr + '我是大刷锅'
                }


            }
        })
    
    
    </script>
</body>
</html>